<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
	<title>使用查询领域专属语言搜索 | Elasticsearch: 权威指南 | Elastic</title>
    <!-- Give IE8 a fighting chance -->
    <!--[if lt IE 9]>
    <script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
    <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
    <![endif]-->
	<link rel="stylesheet" type="text/css" href="../static/styles.css" />
</head>
<body>
<div class="main-container">
    <section id="content">
        
        <div class="content-wrapper">
            <section id="guide" lang="zh_cn">
                <div class="container">
                    <div class="row">
                        <div class="col-xs-12 col-sm-8 col-md-8 guide-section">
                            <div style="color:gray; word-break: break-all; font-size:12px;">原文地址: <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/_search_with_query_dsl.html" rel="nofollow">https://www.elastic.co/guide/cn/elasticsearch/guide/current/_search_with_query_dsl.html</a>, 版权归 www.elastic.co 所有<br/>
                            英文版地址: <a href="https://www.elastic.co/guide/en/elasticsearch/guide/current/_search_with_query_dsl.html" rel="nofollow">https://www.elastic.co/guide/en/elasticsearch/guide/current/_search_with_query_dsl.html</a>
                            </div>
                        <!-- start body -->
                  <div class="page_header">
<b>请注意:</b><br>本书基于 Elasticsearch 2.x 版本，有些内容可能已经过时。
</div>
<div id="content">
<div class="breadcrumbs">
<span class="breadcrumb-link"><a href="index.html">Elasticsearch: 权威指南</a></span>
»
<span class="breadcrumb-link"><a href="getting-started.html">基础入门</a></span>
»
<span class="breadcrumb-link"><a href="intro.html">你知道的, 为了搜索…​</a></span>
»
<span class="breadcrumb-node">使用查询领域专属语言搜索</span>
</div>
<div class="navheader">
<span class="prev">
<a href="_search_lite.html">« 轻量搜索</a>
</span>
<span class="next">
<a href="_more_complicated_searches.html">更复杂的搜索 »</a>
</span>
</div>
<div class="section">
<div class="titlepage"><div><div>
<h2 class="title">
<a id="_search_with_query_dsl"></a>使用查询的 领域专属语言(DSL) 搜索<a class="edit_me edit_me_private" rel="nofollow" title="Editing on GitHub is available to Elastic" href="https://github.com/elasticsearch-cn/elasticsearch-definitive-guide/edit/cn/010_Intro/30_Tutorial_Search.asciidoc">edit</a>
</h2>
</div></div></div>
<p>Query-string 搜索 对于从命令行进行临时搜索非常方便，但它有自身的局限性（参见 <a class="xref" href="search-lite.html" title="轻量 搜索"><em>轻量</em> 搜索</a> ）。

Elasticsearch 提供一个丰富、灵活的查询语言叫做<em>查询 领域专属语言 (query DSL)</em>，它支持构建更加复杂、健壮的查询。</p>

<p><em>领域专属语言 (domain-specific language)</em>（DSL）， 指定使用 JSON 作为请求体。我们可以像这样重写之前的查询所有 Smith 的搜索 ：</p>
<div class="pre_wrapper lang-sense">
<pre class="programlisting prettyprint lang-sense">GET /megacorp/employee/_search
{
    "query" : {
        "match" : {
            "last_name" : "Smith"
        }
    }
}</pre>
</div>
<div class="sense_widget" data-snippet="snippets/010_Intro/30_Simple_search.json"></div>
<p>返回结果与之前的查询一样，但是可以看到很多变化。其中之一是，不再使用 <em>query-string</em> 参数，而是一个请求体替代。这个请求体使用 JSON 构造，并使用了一个 <code class="literal">match</code> 查询（属于查询类型之一，后面将继续介绍）。</p>
</div>
<div class="navfooter">
<span class="prev">
<a href="_search_lite.html">« 轻量搜索</a>
</span>
<span class="next">
<a href="_more_complicated_searches.html">更复杂的搜索 »</a>
</span>
</div>
</div>

                  <!-- end body -->
                        </div>
                        <div class="col-xs-12 col-sm-4 col-md-4" id="right_col">
                        
                        </div>
                    </div>
                </div>
            </section>
        </div>
    </section>
</div>
<script src="../static/cn.js"></script>
</body>
</html>